<template>
  <el-dialog
    title="分配角色"
    :visible="showRoleDialog"
    @close="btnCancel"
  >
    <!-- el-checkbox-group选中的是 当前用户所拥有的角色  需要绑定 当前用户拥有的角色-->
    <el-checkbox-group v-model="roleIds" align="center">
      <!-- 选项 -->
      <el-card
        class="box-card"
        shadow="never"
        body-style="padding: '30px'"
      >
        <el-checkbox
          v-for="item in list"
          :key="item.id"
          :label="item.id"
        >
          {{ item.name }}
        </el-checkbox>
      </el-card>

    </el-checkbox-group>
    <el-row
      slot="footer"
      class="dialog-footer"
    >
      <el-button
        @click="btnCancel"
      >取消</el-button>
      <el-button
        type="primary"
        @click="btnOK"
      >确定</el-button>
    </el-row>
  </el-dialog>
</template>

<script>
// 这个方法之前在公司设置---角色管理的时候写过了
import { getRoleList } from '@/api/setting'

import { getUserDetailById } from '@/api/user'

import { assignRoles } from '@/api/employees'

export default {
  // 组件名称
  name: '',
  // 局部注册的组件
  components: {},
  // 组件参数 接收来自父组件的数据
  props: {
    showRoleDialog: {
      type: Boolean,
      default: false
    },
    // 用户的id 用来查询当前用户的角色信息
    userId: {
      type: String,
      default: null
    }
  },
  // 组件状态值
  data() {
    return {
      list: [], // 角色列表
      roleIds: []
    }
  },
  // 计算属性
  computed: {},
  // 侦听器
  watch: {},
  // 以下是生命周期钩子   注：没用到的钩子请自行删除
  /**
  * 组件实例创建完成，属性已绑定，但DOM还未生成，$ el属性还不存在
  */
  created() {
    this.getRoleList()
  },
  /**
  * el 被新创建的 vm.$ el 替换，并挂载到实例上去之后调用该钩子。
  * 如果 root 实例挂载了一个文档内元素，当 mounted 被调用时 vm.$ el 也在文档内。
  */
  mounted() {
  },
  // 组件方法
  methods: {
    //  获取所有角色
    async getRoleList() {
      const { rows } = await getRoleList()
      this.list = rows
    },
    async getUserDetailById(id) {
      const { roleIds } = await getUserDetailById(id)
      this.roleIds = roleIds // 赋值本用户的角色
    },
    async btnOK() {
      await assignRoles({ id: this.userId, roleIds: this.roleIds })
      //   关闭窗体
      this.$emit('update:showRoleDialog', false)
      this.$message.success('编辑成功')
    },
    btnCancel() {
      this.roleIds = [] // 清空原来的数组
      this.$emit('update:showRoleDialog', false)
    }
  }
}
</script>

<style scoped lang="less">

</style>

